using System;

namespace Work.API.Dtos.DrugManagement
{
    /// <summary>
    /// 药品出库记录DTO（用于药品出库和查看已发药品模块）
    /// </summary>
    public class DrugOutboundDto
    {
        /// <summary>
        /// 出库记录ID
        /// </summary>
        public int OutboundId { get; set; }

        /// <summary>
        /// 药品ID
        /// </summary>
        public int DrugId { get; set; }

        /// <summary>
        /// 药品名称（冗余字段，便于显示）
        /// </summary>
        public string? DrugName { get; set; }

        /// <summary>
        /// 处方明细ID（可选，用于追溯）
        /// </summary>
        public int? PrescriptionItemId { get; set; }

        /// <summary>
        /// 预约编号（可选，用于追溯）
        /// </summary>
        public int? AppointmentId { get; set; }

        /// <summary>
        /// 患者ID
        /// </summary>
        public int PatientId { get; set; }

        /// <summary>
        /// 卡号（冗余字段，便于快速查询）
        /// </summary>
        public string? CardNumber { get; set; }

        /// <summary>
        /// 挂号编号（冗余字段，便于快速查询）
        /// </summary>
        public string? RegistrationNum { get; set; }

        /// <summary>
        /// 患者姓名（冗余字段，便于快速查询）
        /// </summary>
        public string? PatientName { get; set; }

        /// <summary>
        /// 患者性别（冗余字段，便于显示）
        /// </summary>
        public bool? Gender { get; set; }

        /// <summary>
        /// 性别文本
        /// </summary>
        public string? GenderText => Gender.HasValue ? (Gender.Value ? "男" : "女") : null;

        /// <summary>
        /// 患者年龄（冗余字段，便于显示）
        /// </summary>
        public int? Age { get; set; }

        /// <summary>
        /// 患者身份证号（冗余字段，便于显示）
        /// </summary>
        public string? IdCard { get; set; }

        /// <summary>
        /// 出库数量
        /// </summary>
        public int Quantity { get; set; }

        /// <summary>
        /// 出库单价（销售价格）
        /// </summary>
        public decimal UnitPrice { get; set; }

        /// <summary>
        /// 出库总金额（数量 × 单价）
        /// </summary>
        public decimal TotalAmount { get; set; }

        /// <summary>
        /// 出库日期
        /// </summary>
        public DateTime OutboundDate { get; set; }

        /// <summary>
        /// 操作人（执行出库操作的人员）
        /// </summary>
        public string? Operator { get; set; }

        /// <summary>
        /// 备注
        /// </summary>
        public string? Remarks { get; set; }

        /// <summary>
        /// 创建时间
        /// </summary>
        public DateTime CreateTime { get; set; }
    }
}

